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A 4051 Graphic System (left), a Kurzweil Reading Machine (center), and a Diablo Hyterm Printer (right), open the world of printed communication to the blind. 
The 4051 connects to the reading machine and the printer simultaneously through a "Y" parallel connector on the RS-232 Option 1 Interface. The Kurzweil 
Reading Machine includes a computer (bottom shelf of the cart), a scanner (top shelf) a control panel and a speaker (both on the left corner of the desk). 
(Photograph by Jeff Shyshka and Curt Campbell, Medical Media Production Service. VAMC, Palo Alto, CA.) 



4051 + KRM = Computer Access for the Blind 



by Gregory L. Goodrich, Richard R. Bennett, 

J. Kenneth Wiley 
Western Blind Rehabilitation Center 
Veterans Administration Medical Center 
Palo Alto, CA 

Historically, blindness has imposed a major limitation on 
the blind population of the world by severely restricting 
their ability to obtain information from print and to 
convey information by print. The statistics and il- 
lustrations of the limitations imposed by blindness are 
almost endless, but you can get some idea the next time 
you type a letter. Just do it blindfolded! 

To be sure, there have been beneficial developments with 
practical applications, such as braille, electric typewriters, 
and portable cassette recorders. But such developments 
are limited by pragmatic considerations. For example, 
braille is bulky (Webster’s Dictionary in braille requires 
36 volumes and occupies a twelve-foot long shelO, and 
braille is read by less than 10% of the blind population. 



Less than 1% of published books are converted into 
cassette tapes as talking books; almost no technical 
material is available on tape. Electric typewriters can be 
used to communicate with the sighted world, but format- 
ting and error detection are very difficult. 

Making Some Progress 

Some unique solutions have been developed to aid the 
visually impaired in the last 10 years. For those who have 
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some visual capacity (about 80% of the total visually- 
impaired population of 2.5 million in the United States), 
specialized optical aids and closed-circuit television have 
been very helpful. For the remaining 500,000 people, 
so£ne direct translation reading machines are available. 
The Optacon (OPtical to TActile CONverter), for exam- 
ple, is a small, battery-operated unit that converts print 
into a tactile image that can be felt on the reader s index 
finger. Reading speeds possible with the Optacon vary, 
but at best are far slower than those possible for a sighted 
reader. 

The expanded development and use of small, inexpen- 
sive, and versatile computers offers another potential aid 
to the visually handicapped. It has become increasingly 
clear that almost any handicapped person can reduce 
his/her problems and increase his/her opportunities by 
learning to interact with computing systems. The tool for 
the sightless to do just that came about in a very recent 
development by Dr. Raymond Kurzweil. His device, the 
Kurzweil Reading Machine (KRM), is a machine that 
converts printed material into speech. A prototype of this 
machine was placed at the Western Blind Rehabilitation 
Genter for evaluation as a reading machine for the blind. 
Researchers immediately began looking at the various 
areas where this machine's potential could be used. 

A 4051 Graphic System and a Diablo Hyterm printer 
were already in use at the Western Blind Rehabilitation 
Center. But the 405 1's ability to store and retrieve data, 
and its editing capacity (405 1R06 Editor ROM Pack), led 
researchers to think about linking the 4051 with the 
KRM. This was a way for blind staff members to gain 
access to a computing system, the 4051, using the speech 
capacity of the Kurzweil machine. 

Linking the 4051 with the KRM brought immediate 
impressive results. After a brief introduction to the 4051, 
one of the center’s blind staff members was able to store 
and retrieve data on the 4051, usingthe voice of the KRM 
both as a means for proofing input and for obtaining 
output (Figure 1). To control text formatting for storage, 
the Editor ROM Pack was used. To control printer 
formatting, the Text Formatting software program 
written by Bruce Clarkson (4050 Series Applications 
Library #5 1 /00-80 18/00) was added to the tape cartridge. 
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Fig. 1. Richard Bennett (seated) and Greg Goodrich key text into the 4051 using 
the4051R06 Editor ROM Pack. The 4051 subsequently transmits the text to the 
Kurzweil Reading Machine which converts it to speech. This audio aid along with 
the 4051R06 editing functions enables the operator to edit text, either as he 
enters it or as he retrieves it from tape. Edited and formatted text is then sent to 
the Diablo Hyterm Printer. (Photographs by Jeff Shyshka and Curt Campbell, 
Medical Media Production Service, VAMC, Palo Alto, CA.) 



More About the Kurzweil Reading Machine 

The Kurzweil Reading Machine was developed by a team 
of experts in computer software design, systems analysis, 
linguistics and phonetics, electrical and mechanical 
engineering, optics, and eduction. They wanted to 
develop a tool that would allow the blind population to 
have rapid access to printed and typewritten material 
This would increase employment opportunities an^ 
personal opportunities for all those with visual handi- 
caps. They reached their goal in 1974, when the first 
complete print-to-speech reading machine prototype was 
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completed. Production models will soon be installed in 
educational, vocational, and rehabilitation centers in 
cities across the United States. 

The KRM uses an optical character recognition system. 
The printed page to be translated is placed on a glass plate 
on the top of the machine, much like an office copier. As 
the machine scans the printed page, the image of each 
character is converted to an electronic signal, forming an 
enhanced image in digital form. A small computer in the 
KRM performs several conversions, then computes the 
pronunciation of each word. Linguistic rules, exceptions 
to the rules, and stress contour computations are drawn 
upon to provide appropriate inflections in the pronuncia- 
tion process. 

The user controls the manner in which the material is 
read. On the simplest level, the user can speed up or slow 
down the reading rate, and adj ust the tonality of the voice. 
Thirty-three other controls allow the user to manipulate 
the machine according to personal needs. The machine 
can be made to repeat the previous few lines, spell out 
obscure w'ords, enunciate punctuation and capitalization, 
or mark certain words for later reference. The position of 
the scanner can also be controlled. A hand-tracking 
option is being developed to allow- the user to rapidly scan 
complicated page formats, develop a mental image of the 
layout, and then proceed to read and follow the printed 
matter. 

To link to the 4051, Kurzweil engineers developed an 
appropriate software program, and developed an RS-232 
input interface to the KRM. No modifications were 
required for the 4051. However, a ''Y" parallel connector 
(Figure 2) was added to allow simultaneous communca- 
tion w'ith the KRM and the printer, and braille markings 
were added to six keys to facilitate typing on the 4051 
keyboard. 

The Results 

The net effect of the system is to provide three things to a 
visually impaired person that had not been previously 
available. The Kurzweil machine provides a means forf 
accessing printed material. Including a 405 1 in the system ' 
adds the ability to store and retrieve data in a fast and 
reliable manner, as well as providing an easily-used means 
for writing and proofing material. 

Some practical applications of "talking computers" were 
demonstrated recently for representatives of the Vet- 
erans Administration, Kurzweil Computer Products, 
Tektronix, and private rehabilitation organizations. 
Since that demonstration, a number of new applications 
have occurred; it appears that we have found only the 
most obvious ones. Access to canned programs, for 
example, can be obtained by changing the display address 
from the 4051 graphic screen to the address of the KRM. 
This provides a voice for the written information, but 



does not display graphics. The hard copy problem might 
be solved by adding a braille computer printer and 
developing a software program which converts Tektronix 
graphics into a form usable by the braille printer. 




Fig. 2. The "Y" parallel connector interfaces the 4051 to the Kurzweil Reading 
Machine and Diablo Hyterm Printer simultaneously. The reading machine's 
control panel lies on the desk behind the connector. (Photograph by Jeff Shyshka 
and Curt Campbell, Medical Media Production Service, VAMC, Palo Alto, CA.) 

Another Option 

The ELINFA Digicassette (manufactured by Elec- 
tronique Linguistique Informatique Appliques in France) 
is a battery-operated cassette recorder that has an 
electronic braille keyboard and 12 refreshable braille 
cells. Each cell contains six mechanically driven pins. 
Information may be recorded on a cassette tape using the 
braille keyboard, or retrieved by activating the pins 
within each of the 12 braille cells. Two ELINFA’s can be 
directly connected to allow a deaf-blind individual to 
communicate with another braille user. The ELINFA can 
also be obtained with an RS-232 interface, equipped with 
an interpreter which translates ASCII to braille and 
braille to ASCII. 

At a recent meeting of the American Association of 
Workers for the Blind, the ELINFA was demonstrated by 
a deaf-blind individual. Although the individual had not 
used his ELINFA to interact with a computer, the 4051 
was linked with the ELINFA. Information was exchang- 
ed quickly and efficiently through the RS-232 interface. 

The applications listed here are relatively few in number. 
However, they have a tremendous potential for the 
handicapped by removing the barriers prohibiting access 
to printed communications and to rapid processing of 
information. And the ease of 405 1 use is accented again by 
the brief introduction necessary before staff members are 
able to use it. JgD 

Editor's Note. Dennis Hagemeier, Tektronix Sales 
Engineer, Santa Clara, observed the demonstration 
mentioned in the article. At his suggestion Dr, Goodrich 
and his associates compiled the story for TEKniques, 
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The 4054 Brings New Graphics and Alphanumeric 
Capabilities to the 4050 Series 

by Cathy Cramer easier and quicker positioning of the crosshair to an exact 

location. 




With over 13 million addressable points on a IS'' screen, the 4054 Graphic 
Computing System can display more graphic and alphanumeric information than 
any other desktop computer. 

TEKniques VoL 3 No. 3 introduced the 4052 and 4054, 
two new desktop systems that join the 4051 to form the 

4050 Series family of compatible Graphic Computing 
Systems. Both the 4052 and 4054 bring major 
enhancements to the 4050 Series. A fast new bit-slice 
processor in both systems provides speed increases in 
computation, graphics, and data communications, The 
increased performance of the 4052 and 4054 makes them 
highly responsive, and thus more interactive than other 
desktop computers. The large memory option (64K) 
combines with fast processing to make larger or more 
complex applications more practical than ever before. 

The 4054 has all of the features of the 4052, without 
exception. In addition, the 4054 offers graphics and 
alphanumeric capabilities never before seen in a desktop 
computer. 

Graphics 

The 4054 provides superior high resolution graphics on a 
19'' DVST display. With its large screen, the 4054 can 
display more information than any other desktop com- 
puter, and with greater precision. Dense, complex images 
can be displayed using 4096 x 3125 viewable points— -over 
sixteen times the capacity of the already high-resolution 

4051 and 4052. 

Graphic Input 

With the 4054, a full-screen crosshair cursor provides the 
graphic input capability. The POINTER command 
activates the crosshair, the same way it activates the 
blinking arrow cursor on the 4051 and 4052. You can 
manipulate the crosshair using two new thumbwheels, 
which come standard, on the far right of the 4054 
keyboard: one thumbwheel moves the cursor up or down; 
the other moves it left or right. Each position of the 
thumbwheels corresponds to a point on the screen, for 



The thumbwheels eliminate the need for a 4952 Option 2 
Joystick. But if you prefer the Joystick, you can use it to 
manipulate the crosshair by simply connecting the 
Joystick and pressing the SELECT button. 

Graphic Displays 

Graphic Displays can be generated very quickly on the 
4054, for two reasons. First, the new high performance 
processor cuts down the amount of time spent on 
computations involved in the display; whether the com- 
putations are just conversions of user units to graphic 
display units, or complex mathematical routines to 
compute coordinates. Second, the raw speed at which 
vectors are drawn is faster on the 4054, due to a new 
vector generator. 

The new vector generator draws at a constant rate of 
15,000 cm /sec, for consistently crisp and clear vectors. 

The time required to draw a vector is proportional to its 
length: the shorter the vector, the faster it draws. You can 
save considerable drawing time over the 4051 and 4052, 
whose "constant time" vector generator takes the same 
amount of time to draw any vector, regardless of length, g 

t 

Ail vectors draw faster on the 4054. The longest possible 
vector, a full-screen diagonal, shows the smallest increase; 
drawing about 25% faster than on the 4051 or 4052. Short 
vectors benefit the most from the new vector generator. A 
5 cm vector draws about 10 times faster on the 4054, and a 
1cm vector is over 55 times faster. Taking into considera- 
tion the time required to compute coordinates and 
execute graphics commands, you can expect the 4054 to 
generate graphic displays up to 50% faster than even the 
4052, making the 4054 especially suited for applications 
that are heavily graphics oriented. 

Dashed Vectors 

As a special graphics feature incorporated into the 
hardware, the 4054 can generate dotted or dashed vectors 
in a variety of patterns. A particular pattern can be 
selected using a new BASIC keyword DASH along with a 
number from 0 to 255, like this: 

DASH 1 

The above command tells the 4054 to draw subsequent 
vectors with long (about 1.3 cm) dashes. You can enter a 
DASH command such as this one directly from the 
keyboard or under program control; and you can change 
the dash pattern at any time simply by entering a DASH g 
command with a different parameter, or executing v 
DASH 0 or INIT to revert to the default solid line 
vectors. 

The DASH command completely eliminates the need for 
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BASIC software to generate dotted and dashed vectors. 
The benefits are many. First, there’s the simple con- 
venience of being able to enter one command instead of a 
software routine. You save program development time, as 
well as valuable memory space. The 4054 offers 36 unique 
selectable patterns, for a high degree of flexibility. A 
BASIC software routine to generate this many patterns 
could require in excess of 6K of user memory. Also, 
because the 4054 dashed vectors are handled by 
hardware, they draw much faster than equivalent 
software-generated vectors. You save considerable draw- 
ing time using the 4054 DASH command instead of 
custom-written routines (a factor of over 1 00 times for the 
Data Graphing example shown in Figure 6). 

The unique vector patterns you can select using the 
DASH command are shown in Figure 1, along with the 
pattern number for obtaining each one. For example, 
DASH 85 gives short dashes, and DASH 5 gives long 
dashes separated by very short dashes. Not shown in the 
figure are DASH 0 (solid vectors), and DASH 255 
("dark" or invisible vectors). 

Dashed vectors can make graphic displays more 
meaningful, and easier to interpret. You can use different 
vector patterns to distinguish multiple curves on a graph. 
Or, you can represent theoretical curves with dashed 
vectors, and actual data with solid vectors. Hidden lines 
or tool cut lines are also good candidates to be drawn with 
dashed rather than solid vectors. 

There are many other applications. The example showm 
in Figure 2 depicts a multiple feedback low pass filter. The 
lower portion of the display plots both actual and 
theoretical frequency versus gain curves for the filter. The 
actual distribution is plotted using the default solid 
vectors. But the ideal or theoretical curve is plotted using 
the very short dash vector pattern, selected by the 
command DASH 85. 

A quick note about how the DASH command works: the 
parameter of the DASH command is the decimal 
equivalent of an 8-bit representation for a particular 
pattern. A bit that is off (0) turns the writing beam on, and 
a bit that is on (1) turns the writing beam off. Each of the 
eight bits corresponds to .71 graphic display units 
(GDUs), and the pattern that results is used repeatedly to 
generate dashed vectors. In theory, this gives you 2^ or 256 
selectable patterns; but because the pattern is placed end- 
to-end repeatedly when drawing vectors, there are actual- 
ly 36 unique patterns— probably more than you’ll ever 
need. 

A final point about the DASH command is that the 4054 
"remembers" what portion of the pattern it is drawing as it 
ends each vector. So if the next vector begins at the 
endpoint of the previous one, the pattern simply con- 
tinues, rather than restarting and destroying the 
appearance of the graph or design. 



Alphanumerics 

The 4054 draws all characters with vector strokes, rather 
than dot patterns as on the 4051 and 4052. Because the 
stroked characters are continuous, they’re extremely 
clear, and easy to read. The hard copies are excellent. And 
like the 4052, the 4054 has an expanded set of character 
fonts, including the new business font with the "slashless" 
zero (shown in Figure 4). 

Character Sizes 

The 4054 is the first desktop computer to offer four 
character sizes. The four sizes, shown in Figure 3, are 
selectable from the 4054 keyboard or under program 
control using a new BASIC command CHARSIZE. You 
can select a character size at any time; just enter the 
keyword CHAR followed by a digit 1 through 4. 
Character size 1 is the smallest, with 132 characters per 
line, and character size 4 is the largest, with 72 characters 
per line as on the 4051 and 4052. 

You’ll find the choice of several character sizes has major 
advantages in both purely alphanumeric applications, 
and applications that mix alphanumerics with graphics. 
Some examples are shown in Figures 4 through 6. The 
smallest character size displays 132 characters per line, 
making the 4054 the world’s first desktop computer that 
can be used to preview 132-column line printer output 
with no overwriting or wraparound (Figure 4). The small 
character size is also convenient for BASIC program 
development or debugging, because it lets you inspect 
almost twice as many program statements as you're 
accustomed to seeing on the 4051 at one time. And the 
more statements you can examine at once, the easier it is 
for you to keep track of the flow of your program. 

The two-column listings under control of the EDITOR 
ROM pack are optimized using the 4054’s small character 
size (Figure 5). You can display 60 characters per line in 
each of the two columns, with no overwriting of the 
second column by the first, and no wraparound in the 
second column. 

Finally, the most well-known application for multiple 
character sizes is enhancing graphic displays with te.xt 
annotations of varying sizes (Figures 2 and 6). Titles, a.xis 
labels and numeric values, legends and tables can all be 
differentiated and highlighted according to their impor- 
tance or their placement on the page, using the four 
character sizes. In Figure 6 the overall title is in character 
size 4, but the footnote under the title is in the small 
character size 1. X and Y axis labels are made with size 3. 
The legend in the lower left corner and the numeric values 
labeled on the X and Y axes are displayed in size 2. 
Appropriate use of multiple character sizes on graphic 
displays lets you place the emphasis where needed, and 
puts the final touch on high-quality presentations. And 
not to be ignored is the fact that in many instances, the 
smaller character sizes allow you to display extra te.xt that 
you couldn't have otherwise fit on the page. 
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Fig. 2. Dashed vectors help differentiate theoretical curves from actual data. 




4054 CHARACTER SIZES 
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Fig. 4. The 4054 can be used to preview a page of 1 32-coiumn iine printer output at a giance. 
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Fig. 5. Two-column listings under control of the EDITOR ROM Pack can display 60 characters 
in each column with no overwriting or wraparound. 
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Fig. 6. Multiple character sizes can be used to differentiate or highlight text annotations on a 
graphic display. (Actual size of display is almost twice the size shown here.) 




Automatic Data Handling of Uranium Analysis for the NURE 
Program 



by Stanley T. Kosiewicz 

Los Alamos Scientific Laboratory 
Los Alamos, NM 




Fig. 1. The Tektronix 4051 Graphic System is the controller in the automated 
system which analyzes pelleted samples for uranium. A fluorometer 
modified to include a digital voltmeter (left), and a printer /storage 
terminal (right) complete the system. 

Since 1975, the Los Alamos Scientific Laboratory 
(LASL) has been participating in the National Uranium 
Resources Evaluation (NURE) program. In that 
program, three laboratories are assessing the nation’s 
potential uranium resources. LASL’s responsibility area 
has been the Hydrogeochemical and Stream Sediment 
Reconnaissance (HSSR) of New Mexico, Colorado, 
Montana, Wyoming, and Alaska. The other laboratories 
involved in the program. Oak Ridge Laboratories in the 
middle west and Savannah River Laboratory for the east 
and west coast, are performing similar studies. 

Evaluting Samples 

Scientists collect samples throughout the subject area. In 
the contiguous United States, a sample is collected every 
four square miles, while in Alaska a sample is collected for 
each 10 square mile area. The samples are then sent to the 
laboratory for analysis. At Los Alamos Scientific 
Laboratory the pellet fluorometric method determines 
the quantity of uranium in the sample. The method works 
like this: Water samples are gathered in the field for 
testing. These samples are dried under a heat lamp, and 
the resulting deposit is mixed with a matrix of lithium 
fluoride with sodium fluoride. This mixture is placed in a 
platinum cup and fused to make a pellet. Subjecting the 
pellet to ultraviolet light produces a fluorescence which 
can be measured by a fluorometer, The amount of 
fluorescence in the pellet is proportionate to the amount 
of uranium in the original sample. LASL processes about 
38,000 samples per year by this method. 

At the start, the analyses were done by hand. Sample 



readings from a fluorometer were written down on paper. 
When enough readings had been recorded, a technician 
processed them using a desktop calculator. The result was 
usable data on sample concentrations that could then be 
compared against rejection criteria. Data was later 
transferred to a host computer for storage. Manual 
processing of the analytical data for these samples 
demanded a lot of time and labor. Additional effort was 
required to check the accuracy of data collected in this 
manner. 

Now an automated system controlled by the 405 1 recdrds 
the data and analyzes the readings quickly and easily, 
with less chance for error. The system is interactive; 
instructions to the operator are displayed on the 4051 
screen. 

The 4051 is interfaced with a fluorometer to obtain 
readings from the test samples; the interface occurs 
through a controllable digital voltmeter connected to the 
405 1 through the GPIB. The digital voltmeter samples the 
signal generated by the fluorometer upon command from 
the 4051 Graphic System. 

After blanks, controls, standards, and sample pellets are 
read, the 4051 performs a least squares calculation to 
make a concentration curve. The uranium concentrations 
of all pellets read are then tested against all rejection, 
precision, and diagnostic criteria in the current water 
analysis laboratory guidelines.* Subsequently, the con- 
centrations and diagnostics (if any) are transmitted over 
the RS-232 interface to a terminal for printing. If a set of 
samples has not been rejected, the sample identifications 
and concentrations are transferred directly to a magnetic 
tape cassette, where they are available for additional 
processing. Data are stored on a host computer, and are 
available to the public for uranium mining research. 

Equipment Configuration 

The following items, shown in Figure 1, were used to 
automate the data- acquisition and processing. 

(1) Fluorometer. A Jarrell Ash 26-000 fluorometer was 
used, with the meter replaced by a digital voltmeter. 
Positive output is taken from pin 2 of the DVM, 
while negative output is taken from pin 10. The 
fluorometer DVM reads in millivolts. 

(2) Digital Voltmeter. The signal from the fluorometer is 
transmitted to a Fluke 8500 A DVM equipped with 
an optional IEEE-488 (GPIB) interface. Two DVMs 
are connected to the 4051. The DVMs are remotely 
controlled through an address of 1 or 2. The 

*A Los Alamos Scientific Laboratory internal document. 



12 



instruments are operated in a dc volts mode with a 
maximum range of 312.5 mV. This range will never 
' be exceeded under any conditions to be encountered 
in trace uranium analyses of natural waters. 

(3) Computing System. The Tektronix 4051 Graphic 
System, equipped with an RS-232 optional interface 
and 16K memory, processes the signal from the 
Fluke DVM. Using the graphic display, the com- 
puter asks questions of the technician and also 
displays the technician’s responses entered from the 
keyboard (Figure 2). The BASIC language computer 
program is stored on the 405 1’s internal magnetic 
tape. The 405 1 commands the Fluke DVM to sample 
the fluorometer signal and subsequently to send the 
data to the 4051 for processing into concentration 
data. The data are then sent to a TI 733 terminal, 
w'hich is used merely as a controllable typewriter and 
tape recorder. 



E'-TES SAMPLE NUMBER 

I-: Tnli SAMPLE A CONCEHTPftTE? 1 FOP YES. 0 FOP NO. 

0 

lC-aO first pellet fop 3392f>9 HIT RETURN WHEN REHOY TO READ 
HTtWHHl FLUOPOMETEP SCALE WaS USED? .01 OP 
* SI . '29 

LOAD skOND PELLET FOP 339299 RETURN WHEN REmDY TO READ 
31.73? 

DO :0U AmHT to repeat THIS SAMPLE? 

;c,i-iPLE = 33A2A^ 

T3 REPE-iT TYPE 1. TYPE 0 TO CONTINUE. 



Fig. 2. The operator interacts with the system through instructions displayed on 
the 4051 graphic screen. 

(4) Flard Copy Terminal. A Texas Instruments 733 ASR 
terminal prints the concentrations and also records 
them on a magnetic tape cassette. The terminal is 
remotely controlled through the RS-232 interface 
using an address of 40. Upon command from the 
4051, the terminal prints the concentrations (Figure 
3). Then only acceptable data that are within 
established analytical guidelines are recorded on the 
terminal’s magnetic tape cassette, again upon com- 
mand from the 4051. In addition, data from the 
TI 733 terminal can be sent to the LAST Central 
Computing Facility over the RS-232, via an acoustic 
coupler. 

A continuing check of field water samples compares the 
405 1 -generated data against that obtained manually with 
a desktop calculator. Comparisons made on more than 
500 samples so far demonstrate excellent agreement 
between the two methods. Figure 4 displays uranium 
concentration data from 60 samples processed using a 
desktop calculator versus data obtained "automatically" 
using the 4051 system. The barely-visible dashed lines in 
the graph are the 95% confidence limits. 

Conclusions 

The automated data acquisition and processing system 



decreases labor, saves time, and eliminates manual errors 
in computation. Manual keypunch operations previously 
required to transmit data to the Central Computing 
Facility are eliminated resulting in large additional time 
and labor savings. 
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Fig. 4. Urafiium concentrations obtained manually for 60 samples demonstrate 
excellent agreement with those obtained for the same 60 samples 
through the automated system. 



Finally, sample throughput may also increase since the 
technician operator knows immediately whether a sample 
or set of samples must be repeated. Operator satisfaction 
appears to have increased because of the smoothness and 
simplicity with which they interact with the 405 1 Graphic 
System and the immediate feedback they receive from it. 
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associates at the University of California, Los Alamos 
Scientijic Laboratory, was brought to TEKniques atten- 
tion by Wayne Avila, Tektronix Sales Engineer at 
Albuquerque. More detailed information on the program 
is contained in LA-7648-MS Informal Report, UC-51, 
issued Feburary 1979. 







Register for the PLOT 50 Software Maintenance Newsietter 



by Howard Sanders 

Are you registered for the PLOT 50 Software 
Maintenance newsletter? If not, fill out the Product 
Update Registration card in your 4050 Reference manual 
or your software manual(s). Registrants will receive the 
periodic newsletter listing verified PLOT 50 software 
problems and how to correct or bypass these problems. 

PLOT 50 software products are those developed and 
supported by Tektronix for the 4050 Series and to date 
include the following packages: 

4050 AO 1 PLOT 50: Statistics Vol. 1 
4050A02 PLOT 50: Statistics Vol. 2 
4050A03 PLOT 50: Statistics Vol. 3 
4050A04 PLOT 50: Mathematics Vol. 1 
4050A05 PLOT 50: Mathematics Vol. 2 
4050A06 PLOT 50: Electrical Engineering Vol, 1 
4050A07 PLOT 50: Graph Plot 



4050A08 PLOT 50: General Utilities Programs 
Vol. 1 

4050A09 PLOT 50: Business Planning and Analysis 
Vol. 1 

4050A10 PLOT 50: Statistics Vol. 4 
4050A13 PLOT 50: Statistics Library 
4050A14 PLOT 50: Mathematics Library 
4050A15 PLOT 50: Scientific Library 

Much of the information in the newsletter is developed 
from customer comments or reports of software 
problems. Please send in any comments or reports of 
errors. Contact your local Tektronix Systems Analyst for 
help in submitting a Software Performance Report. 

NOTE: 4050 BOl Modeling and Reporting is supported 
and updated, but not through the PLOT 50 
Sojtware Maintenance Newsletter. 



Signal Processing ROM Pack#1 Speeds Up Numeric Sorting 



by Dave Barnard 

How could the Signal Processing ROM Pack #l 
(405IR07 or 4052R07) possibly improve numeric value 
sorting, or even relate to such a task? Someone really did 
ask that question. The answer is that it relates very well, 
and significantly improves the performance of even the 
simplest sorting program. Although Signal Processing 
ROM Pack #l was designed for waveform, signal, and 
time-series analysis,* its functions can be applied to any 
one-dimensional array of numeric values. It can also 
operate on numbers stored in 4050 Series Graphic System 
memory, for sorting operations. 

With a few changes a bubble sort program can take 
advantage of the power and speed of the Signal Process- 
ing ROM Pack #l. The changes are easy to implement 
and easy to understand. Although more powerful sorting 
algorithms exist, they won’t outrun the simple ROM 
Pack-enhanced bubble sort until the number of values 
sorted exceeds 1 500 for the 4051, or 2400 for the 4052. 

Bubble Sort Program 

Let’s look at a simple bubble sort program (Figure 1). 
Each time an inner loop consisting of lines 1110 through 
1210 is executed, the numbers in the array are only 
partially ordered. For badly scrambled numbers, line 
1090 will command entry of the loop almost N times, or as 



many times as there are numbers in the array. And the 
FOR. ..NEXT loop must examine N-1 values for each 
repetition. Therefore, sorting time could be proportional 
to N*N (N = the number of values to be sorted). Even if all 
the numbers are in sequence, the FOR... NEXT loop must 
be executed once; that’s N-I executions of some of the 
lines in the loop. But, when the quantity of numbers to be 
sorted is small, the bubble sort is an easy solution that is 
often fast enough. 

How'ever, when sorting only 80 numbers, this routine 
takes approximately two minutes. The lengthy execution 
occurs because line 1 130 simply compares two neighbor- 
ing values to determine if they’re out of sequence. The 
limited information provided by this comparison only 
allows partial re-ordering of the values during each run of 
the FOR... NEXT loop. 
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*A previous TEKniques article (Vol. 2 No. 7) described the seven 
functions that the 4051 R07 performs. 
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Fig. 1. Simple Bubble Sort program. 




But suppose that the entire array could be searched, 
instead of comparing just two points in the array. The 
approach would be a more direct, logical series of steps: 

1. Examine all the numbers until you find the biggest. 

2. Put the biggest number at the end of the array (and 
save the old end number in the place where you found 
the biggest one). 

3. Narrow your search as though the array is shorter by 
one number (don't again look at numbers you have 
sorted). 

4. Go back to 1 and repeat until you have to search only 
one number — you’re done. 

That’s closer to the way people sort numbers. For a 
collection of numbers (N of them) the process involves 
searching for the largest (or smallest) number only N-1 
times. 

Signal Processing ROM Pack #1-Enhanced Bubble 
Sort 

With the ''MIN" or "MAX" commands of the Signal 
Processing ROM Pack #l, you can sort numbers in the 
way just described. The sort program (Figure 2) replaces 
the one in Figure 1. Line 1110 determines whether the 
"MAX" or "MIN" command is used for ascending or 
descending sorting. The variable A1 always points to the 
last number in the array of unsorted numbers. The CALL 
ZS A,V,I statement finds the largest (or smallest when 
ZS - "MIN") number and its location, providing much 
stronger direction (more information) for the sorting 
operation. The limits of the search ("MAX" or "MIN" 
command) are decreased by one each time through the 
FOR... NEXT loop, by re-dimensioning the array. Only 
N-1 times through the loop sorts all N of the numbers. 

The execution time is still proportional to N*N but only N 
(approximately) loops occur in BASIC. Searching for the 
largest number among N numeric values is delegated to 
the ROM Pack. That is, the loop contained in statements 
1 1 10 to 1 190 in Figure I is replaced by the firmware in 
Figure 2 (statement 1140) with the resultant increase in 
speed. The 80 number numeric sort that took two minutes 
without the ROM Pack Function takes only five seconds 
using the "MAX" command of the ROM Pack. 

Enhanced Bubble Sort vs. Quick Sort 

For larger sizes of sorting problems a different routine is 
useful: the Quick sort. Such a routine is contained in the 
General Utilities Program Vol. 1 (4050A08). The Quick 
sort conquers the sorting problem by subdividing it which 
makes the execution time proportional to N log,Q N 
instead of N*N. However, for smaller sorting tasks, the 
ROM Pack-assisted bubble sort is faster than even the 
Quick sort. Eventually its proportionality to N’^N slows it 
down and the Quick sort algorithm becomes faster. 



The table in Figure 3 compares the measured times for 
performing sorts on various numbers of values in the 
4051. When approximately 1500 numbers are sorted, the 
Quick sort program from the General Utilities Vol. 1 pulls 
out in front. 
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Fig. 2. Bubble Sort program modified to use 4051R07 ROM Pack. 



For larger applications a 4052R07 Signal Processing 
ROM Pack# I combined with the 4052 or 4054 provides a 
powerful tool. With the greater speed and larger memory 
nearly intractable problems become solvable. Figure 3 
also compares a 4052R07-assisted bubble sort in the 4052 
to a Quick sort in the same machine. The point at which 
the Quick sort method becomes faster than the simpler 
sorting program has moved to a new plateau (ap- 
proximately 2400 points). 

Thus, the versatility of the Signal Processing ROM Pack 
provides a new, easy-to-use, efficient alternative to the 
simple but slow bubble sort at the one extreme, and the 
powerful Quick sort algorithm at the other. 

This is only one of many applications of the Signal 
Processing ROM Pack #l that lies outside the realm of 
signal processing. We are interested in other applications 
that transcend the question of whether the data came 
from a DPO, 7912AD, other instrumentation, or no 
instrumentation at all. As we find them we’ll report them. 
Let us hear of applications you may have found. 
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Fig. 3. Execution time for sorting methods. 





*Edltor’s Note 



Programming Tip Exchange 
Continues 



Have you found a small piece of programming informa- 
tion in the course of your work that you think others 
might find useful as well? We'd like to hear about it, and 
publish it for Others as a Programming Tip ora Basic Bit. 
Send it in to the Applications Library. Any one of the 
following Applications Library Programs will be yours 
when it’s published. Simply jot down a brief description 
of its function, the code, and your choice of program. 
Mail the information to the Applications Library address 
serving you; the addresses can be found at the back of 
each issue. 



51/00-0101/0 

51/00-0702/0 

51/00-0715/0 

51/00-1401/0 

51/00-1402/0 

51/00-5401/0 



51/00-5503/0 

51/00-7002/0 

51/00-8006/0 

51/00-9505/0 

51/00-9511/0 

51/00-9521/0 



’"Documentation and listing only. 



Your New Catalog is Here! 

You’ll notice that this issue of TEKniques is accompanied 
by a new Applications Library catalog. This catalog 
contains 40 new programs that have been added to the 
library since that last catalog. Look through it. Ad- 
ditional copies are available for the asking, from the 
Applications Library office serving you. The 
Applications Library staff thanks ail of you who con- 
tributed to the Library, and made these additional 
programs available to others. 



We’re 4050 Series Now 

Perhaps you’ve already noticed that, beginning with the 
last issue, we changed the name of our newsletter. We’re 
now 7 EKniques, the 4050 Series Applications LJhrary 
Newsletter. This change represents our support for the 
entire 4050 Series of Graphic Computing Systems. As 
more of you begin to use the 4052 and the 4054, we’ll be 
featuring programs, programming tips, and applications 
articles that feature those devices as well as the 4051. 

Program Prices are Changing 

Beginning August !, 1979, prices for Applications 
Library Programs will be increasing. The increase is the 
first since the Applications Library began, and represents 
increased material, labor and distribution costs. The new 
domestic prices are as follows: 

Documentation and 
Listings 
Recording Fee 
Tape Cartridge 



$20 per program 
5 per program 
30 per tape 



Did You Miss an Issue? 

The TEKniques office has copies of ail previous issues of 
TEKniques available, for those of you who are new 
members or otherwise missed or lost an issue. If you’d like 
to receive a copy of any previous issue, just drop a line to 
the Applications Library address serving you. The 
addresses are located at the back of each TEKniques 
issue. ^ 



Space Shuttle Project Progresses 



Bob Wheeler, whose 4051-aided space shuttle project was 
featured in TEKniques Vol, 3 No. 2, is going places with 
his project. At the Weber High School Regional Science 
Fair, Bob’s project placed first in two categories: Math 
and Science Engineering Reporting, and Math and 
Engineering Projects. In doing so, he captured one of the 
four expense-paid trips to the General Motors Science 
and Engineering Fair held in San Antonio, May 7-16. 

At San Antonio Bob placed fourth in the Math and 
Computers competition. As a result he will receive a trip 
to Jet Propulsion Laboratory at Pasadena in early July. 
This trip will coincide with the rendezvous of the 



unmanned spacecraft Voyager 2 and giant planet Jupiter 
on July 9, which event Bob will be able to observe on the 
deep space tracking network of JPL. 

In addition. Bob will be taking his project on another 
outing. To commemorate the tenth anniversary of the 
first manned moon landing on July 21, 1969, NASA will 
be holding celebrations in two cities: Washington, D.C. 
and Salt Lake City. Bob has been asked to display his 
project along with other projects at the Hanson 
Planetarium in Salt Lake City and to meet with the 
astronauts who will be on hand for the festivities. Lunar 
Landers will be on display at the ZCMI Mall. ^ 
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Programming 




More Updates on 
Flowcharter Program 
51 / 00 - 8005/1 

Shift Rubout NOT Ctrl Rubout 

by Chester E. Fox, Jr. 

Naval Research Laboratory 
Washington D.C. 

Line 5080 of the newest version (lines 5 1 70 or 5070 of 
older versions— see the update in TEKniques Vol. 2 No. 
5) contains an error. The code looks okay on paper, 
however, the last character should be a SHIFT 
RUBOUT, not CTRL RUBOUT. 

5889 

Ed Note: Unfortunately, we entered the wrong code when 
updating our master. 

Control Characters In IMAge 
Statements 

by N.J.J. Ogbourne 

Comalco Aluminum (Bell Bay) Limited 
George Town, Tasmania 

Control characters enclosed in literal string in IMAge 
statements are not "stripped;" e.g.,: 

IHAGE •CdIJKL* 

The following example shows code from the newest 
version of Flowcharter, along with code which corrects 
this oversight: 

PRESENT CODE: 

1440 C0SU6 2008 
1450 P«P0S<L*,‘ M> + 1 
1460 C»»SEC(L»,P,3> 

14?0 C»<P0S<ft»,C*il)+2>/3 

1480 IF COl OR POSa*,*»*,P)-0 THEN 1510 




CHANGE TO: 




4051 Drives Plotter Through RS-232 

by Mark Mehall 
Tektronix, Inc. 

Chicago 

405Ngenerated plots and drawings can be sent to any 
remote 4660 Series Plotter or 40 1 0 Series Terminal over 
the Option I RS-232-C Interface. However, graphic data 
transmitted over the RS-232 Interface must address the 
Plotter surface coordinates, or the terminal screen 
coordinates, as binary numbers rather than graphic 
display units. Each coordinate is represented by a 12-bit 
binary number. The 24-bits for the two coordinates are 
specified by transmitting five appropriate ASCII 
characters over the Interface; the ASCII value of each 
character contains a segment of the 24-bit pattern. 

The first ASCII character determines the five most 
significant bits of the Y coordinate (HIY). The second 
character specifies the two least significant bits of Y and 
the two least significant bits of X (XLOY). The third 
ASCII character specifies the five intermediate bits of the 
Y coordinate (LOY). The last two ASCII characters 
determine the five most significant bits of X (HIX) and 
the five intermediate bits of X (LOX), respectively. 

Converting GDU to Binary 

The following routine reads X, Y, Z data points from 
magnetic tape, converts them into ''equivalent" RS-232- 
compatible ASCII characters and transmits the ASCII 
string to the Plotter or terminal in BASIC I/O mode. The 
data points must be in the following form: Z = 20 or 21 
(DRAW^ or MOVE), X = 0 through 130, and Y = 0 
through 100. In this case, the Plotter aspect ratio 
corresponds to that of the 4010-series terminals (Switch 
A = 6). 

Statement 130 defines the modulus function used to 
segment the binary coordinates into ASCII characters. 
Statement 160 initiates the GS control character (ASCII 



♦Shortened addressing may be used; see page 2-26 of the 4662 
Interactive Digital Plotter L'ser’s manual. 
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29) which places the Plotter in Graph Mode. Next, the X 
and Y data from tape are converted to binary coordinates 
(statements 230 and 240). Since we’re using the COPY 
setting (Switch A = 6), the Plotter X-axis runs from Oto 
4095 and the Y-axis from 0 to 3124. 

Statement 280 segments the HI Y bit pattern. Bits six and 
seven of each of the five bytes remain fixed; that is, in the 
HIY b>ne, bit six is always on, thus, we add 32. The 
resulting eight-bit pattern is translated into the ap- 
propriate ASCII character (statement 290), and added to 
the outgoing string (statement 300). The other four bytes 
(XLOY, LOY, HIX and LOX) are segmented, bits six and 
seven modified, and translated into ASCII characters for 
transmission over the RS-232 (statements 310 through 
540). 

Z is now checked to determine whether it’s a MOVE or 
DRAW operation. If it’s a DRAW, just the coordinates 
are sent, since the Plotter assumes a DRAW if no GS 
control character precedes them. If it’s a MOVE, the GS 
control character is included at the beginning of the 
string. (Note the first command must include a GS 
control character to place the Plotter in Graph Mode. 
Therefore the first string is forced to a MOVE operation 
in statement 180.) 

After the data is transmitted, the string is set to null; the 
next data is then read from the tape and processed. 



109 «(EM FMH IS THE MODULUS FUNCTION 
ne REH HMEFE MODf , H2> -A 1 -SGH < X )C I X I 3A2 

129 PEM WHERE X-Al ' A2 

130 DEF FWH‘ H'»IHT<:n-SGN(H' A2>*INT» 

140 Din 0f(8> 

iT0 REH SET C* TO H GS (ADE 29) 
lfc0 C#-CWPc29> 

ir-0 REH SET Of (OUTPUT STRING) TO A GS (G#> 
180 0»«Cf 

190 OH EOF t0) THEN 630 

200 REM READ THE DATA FROM TAPE 

210 INPUT l33:2,X,y 

220 REM GOHUERT TO 8-4095(X) AND 0-3124(Y> 
230 K*X^I3lt4095 
240 Y»V.iee»3124 

250 REM CALCULATE FIRST CHARACTER 

260 REM ICMAR<1>»M0D<KY/128, 32>+32 <HIY> 

270 A2-32 

289 I l»FHM(Y/l28>+32 

290 If-CHR(Il) 

309 0$-0tiI9 

310 REM CALCULATE SECOND CHARACTER (XLOY) 
320 REM ICHAR‘'2>-M0D/’KY>,4)»4+M0D(XXf 4)^96 

339 A2«4 

340 I2-FHM<Y>*4*FNM(X)^96 
350 If-CHR<I2) 

360 Of-Ofllf 

370 REM CALCULATE THIRD CHARACTER (LOY) 

300 REM ICHAR(3)-M0D<KY/4,32.-'+96 
390 A2-32 

400 I3-FMM(Y/4)+96 
410 lf-CHR(I3> 

420 0f«0ftlt 

430 REM CALCULATE FOURTH CHARACTER (HIX> 



440 REM 1CHAR<4>-H0D(KX^ i26.32>>32 
450 A2-32 

46# 14«FHH(X/128>*32 
47# U*CMt(I4> 

4## Ot«Offlt 

4R# REM CALCULATE FIFTH CHARACTER (LOX) 

9## REM ICMAR<5)-M00(KX/4,32)*64 
51# A2«32 

52# I9-FM«^X.'4>464 
530 IfCMRUS) 

5*9 0*»0ft.lf 

55# REM IF Z IS 21 IT S A MOUE (20 IS ,A DRAW) 
560 IF 2-20 THEN 640 

570 REM CHECK IF A MOUE. IF SO INSERT A GS (Cf) 
58# Ot-RER(Ct, 1 .0) 

590 REM OUTPUT THE CHARACTER 
600 PRINT #40; Oft 
618 Of" 



620 CO TO 210 
630 PRINT -DONE." 
640 END 



Page 2-25 of the 4662 Interactive Digital Plotter Users 
manual graphically depicts the binary coordinate values. 





4051-size standard graticule. 

Reproducing Oscilloscope 
Graticules on the 4051 



When you’re examining waveform data graphed on the 
405 1 screen^, it helps to have a reference grid. The 
following subroutine developed by Nathan Oxhandler of 
Tektronix, draws oscilloscope-type graticules on the 405 1 
screen, or on any 405 1 GPIB-controllable display device. 
Five different grids are available: standard, linear-log, 
log-linear, log-log and plain. 



1 IHIT 

2 F-ftC£ 

3 02 TO I »• 

4 CO TO -#«• 

; PETUI?.. 

tea 0*32 

It* STO^ 

5U8»0UT1H£ STARTS HERE 

RHCe 

PRINT 'rix"LOc7T'LIHEftRlilx"LOc7r L5c!4i?Lft7i 
?338 INPUT A# 
i)e4e wiHoou a. taa. ia.9a 
9850 UIEUPOPT 2.5, IE7.5.8, !«• 

9060 PACE ao: 

Agra POR A-a to 10a step la 

?aea ip a*-# and fA-38 or a-70) then jisa 

s<B?a IP Aa-i AND 'M-ia op A-sa oa N-»a,' then aisa 

9iee IP Aa-a ahd A«5a or (Aa-2 aho .a** or a-59 or a«i» 

site AXIS tote.e.A.A 

912* NEX^T A 

9130 CO TO A« OP ?i9a,9I9».919«,»14* 

9140 RETUR.t 

9158 AXIS »0;2,a,A,A 

9160 «tXT A 

9i'^o AXIS to;a.2.A.A 

9180 h£XT a 

9190 FOR A-f TO 9 

92a« POR e-2 TO 9 

921# C»!#*LCT(8>10TA 

9228 CO TO A8 OP 92^6,9238.9278 

9230 CO TO A* OP 9248.9348.9348 

9248 NEXT 8 

9268 RETURN 

■ 9278 I40UE #0:8, C 
9288 ORAN #0: 1 1 C 
92>0 HOUC »0:49,C 
9300 ^RAU »0:5t ,C 
9318 nCwE #0199,C 
9328 C>«AU »0: 188.C 
9338 CO TO 9238 
9348 NOWE fOlC.li 
9358 ORaH #0;C, 11 
936# ITOUE 80:C,49 
9378 C'RAH #0!C.51 
9388 NOME fO:C,89 
93-8 OR AH fO;C,98 
9488 CO TO 9248 



( 



A subroutine to produce five different 4051-size graticules. 



Remember the CTRL Rubout (CHR 13) in statements 
9010 and 9020 format only the 4051 Graphic Screen; they 
are disregarded if sent to any peripheral. 
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4051-size log-log graticule. 







While the above routine draws a 405 1 screen-size grid, the 
following routine offered by Dick Bailey, Tektronix, 
duplicates the Tektronix 7000 Series Oscilloscope 
graticule. 



lIS300*450 

300 REM <DRRH GRATICULE) 

305 PAGE 

3t0 uIEMPORT 30, 130, 10,99 

320 WINDOW 0,511,101.4,920.6 

330 MOVE 0,101.4 

340 DRAW 511,101.4 

150 DRAW 511,920.6 

360 DRAW 0,920.6 

370 DRAW 0, 101 . 4 

330 AXIS 10.24,20.43,255,511 

390 FOR 1*1 TO 9 

400 AXIS 0,0, K51 . 2, Itl02. 4-*>101 . 4 
410 NEXT I 

420 UIEWFORT 30,130,0,100 
430 WINDOW 0,511,0, 1023 
440 HOME 
450 RETURN 



A routine to draw the Tektronix 7000 Series graticule. 



Incorporate either of these routines into your graphing 
program and you’ll have a quick reference grid for your 
signals. 
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The Tektronix 7000 Series graticule. 

*See ''The 4051I9712AD: An Automatic Waveform 
Acquisition System," and "New ROM Pack— Adds Fast 
Graphing and Data Analysis Functions to the 4051," 
lEKniques Vol. 2 No, 7. 



Don’t CALL "MOUNT" With Null 
String 

by Pat Kelley 
Tektronix, Inc. 

The CALL ''MOUNT" command always generates a 
device status message. A target string variable must be 
specified in the command to receive this message. 
Inadvertently, the 4907 File Manager Operator's Manual 
indicated that to save time the message could be 
eliminated by specifying a null string rather than a target 
string variable. To save time, you don't need to look at the 
message, but it is always generated and must have a target 
string to receive it. 

CALL "MOUNT", 0,AI 

^ Target String 



Easy Curves 

by Howard Sanders 
Tektronix, Inc. 




You can draw any length of curve ranging from brief arcs 
to full circles using the following routine. Simply position 
and digitize the three points of the arc in a 
counterclockwise sequence using the 4952 Option I 
Joystick. The 4051 will draw a smooth curve through 
these points. The coordinates developed in statement 
1000 could be stored in a matrix and saved on tape for 
future use. 



lee ftEM SUBffOUTiHE TO ChLCUATE 
110 PEI hH fiiRC FROn THREE POlHTS 
109 !HIT 

13b ;et degrees 

UC POIHTER Xl.M.ftl 
HOWE VI. VI 
■50 RDRhU 0,0 

ira POIHTER XS.Y2.B* 

ISO HOUE 

RCPhW 0.9 

290 POINTER V3,V3,BI 

210 HOUE :-'3.v3 

229 RDfiftW 0,8 

279 Ml=0 

248 B1»0 

258 m2*«2-.V1 

2&8 B2*''2-Y1 

270 Ci3»x3-'''l 

260 57«V3-’'l 

2?0 REM ROTATE POINT 2 UHTR ON THE 'f AXIS 
300 IF A2>0 then 330 
310 Ol^ATHf B2' A2 • 

329 GO TO 340 

730 D1*-.P0 

340 DP-f^e-Dl 

350 IF D1»0 THEN 388 

760 B2«62-SlH.Dn 

770 :o TO 300 

350 62«m2 

799 A2«0 

400 REM ROTATE 3RD POINT 
410 IF A3-0 THEN 440 
420 D3-ATH.'B3'A3> 

430 GO TO 458 

440 03—98 

459 C3«e3-'SIH(03> 

469 03*01^02 

479 B3«SINv'03>tC3 

480 A3-C0S<03.tC3 

598 REM CALCULATE THE RADIUS OF THE ARC 
5 1 0 k«82 ''2 

520 H»(A3»A3+e3»B3-2tKtB3)'<2tA3) 

530 R«SeR<HtH*KtK’) 

540 REM SET THE CENTER OF ARC TO 8,8 

550 A1»A1-H 

568 B1«B1-K 

570 A2«A2-H 

580 B2*S2-< 

590 A3-A3-H 

699 

610 REM FIND THE CENTER OF THE ARC 

620 Cl—Al 

630 C2— 81 

640 D4-ATN(C2^C1) 

650 05«C2/SIH(D4) 

€60 06»D4-D2 
678 Cl»C0SfD6U05 
680 C2«SIN(06>«05 
690 El-Cl+Xl 

700 E2«C2*Y1 

710 REM BEGININC AND END ANGLES OF ARC 
720 Z1«ATH(<Y1-E2'-^(,X1-£1)> 

730 Z2«ATNCri'3-E2)^f.X3-El)) 

740 Zl-INTfZl) 

750 22«IHT(Z2) 

760 IF Yl-E2>0 AND Xl-El<0 THEN 890 

770 IF Yl-E2''0 AND Xl-El<0 THEN 829 

780 IF Yl-E2<0 AND X1-ED0 THEN 840 

790 GO TO 850 

800 2l»Zt+l80 
610 GO TO 850 
820 Zl*2lfl80 
030 GO TO 850 
840 21-360*2l 

850 IF Y3-E2>0 AND X3-EK0 THEN 090 

860 IF Y3-£2''.0 AND X3-EK0 THEN 910 

870 IF Y3-E2<0 AND X3-£l.''0 THEM 930 

080 GO TO 940 

990 Z2-22-^180 

900 GO TO 940 

910 Z2«22>180 

920 GO TO 940 

930 Z2-369>22 

940 IF 2PZ2 THEN 960 

950 GO TO 970 

960 Zl-21-360 

970 REM DRAW THE ARC 

980 MOUE XI, Yl 

990 FOR 1-21 TO 22 STEP 2 

1000 DRAW £ltC0S(l)IR,E2*SIH(P»R 

1010 NEXT 1 

1929 DRAU X3.Y3 



The possibility that any of the three points digitized will 
be identical is extremely remote. Hence, to save code 
error checks have been omitted. However, if it should 
occur, a size dimension error will be generated. 
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specifying Optimum Number of 
Directory Chains in Disc Format 

by Jack Gilmore 
Tektronix, Inc. 

The five digit sequence at the end of CALL "FORMAT" 
and CALL "FFRMT" commands controls how the file 
directory is stored on the disc and affects the access time 
to a file name. Five storage levels are possible on a disc 
with no limit to the number of libraries or files on each 
level (other than disc space). ‘ 

Each level may have one to ten "chains." A chain is a 
sequential listing of library and file names. If there is more 
than one chain on a level, hashing decides in which chain 
the name is placed. Therefore, access time to a file is 
decreased as the number of chains are increased since the 
File Manager is routed through the proper chain and 
doesn't have to search all names on that level. 

The five digits at the end of the two format commands 
specify the number of chains at each level. And the 
number of directory chains at each level should be 
determined by the number of library names or file names 
expected at each level. A general rule of thumb is to divide 
the number of file names at each level by five to arrive at 
the appropriate number of chains for that level.- For 
e.xample, a disc with mostly two level names such as heavy 
use of SCRATCHLIB with over 50 file names should be 
formatted with these five digits as "1,10, 1, L 1" rather than 
"1.1, 1,1,1." On the average, one fifth as many disc reads 
would be required to access a particular file in the first 
example. 



A diagram of the two chaining structures with 50 files in 
SCRATCHLIB follows. In the first example, the proper 
sector is accessed immediately by hashing the file name to 
determine which chain to follow.^ The second example 
may require reading 10 sectors to find the right name. 









Example 2. Chaining route when the last five digits in CALL "FORMAT" or CALL 
"FFRMT" are 




‘ The fifth storage level may contain only file names. 
‘Maximum number of chains per level is 10. 

^ Five library or file names fit into one sector of disc space. 




RETURN Recovers Memory 

by Pat Kelley 
Tektronix, Inc. 



through a RETURN statement. When the RETURN 
command is executed, the 26 bytes of memory dynamical- 
ly allocated to keep track of a FOR/NEXT loop will be 
freed. The following example illustrates the recovery of 
memory. 



LIS 

ide iNiT 

1 le PRINT MEMORY 
ISO GOSUB 500 
130 print memory 

140 END 
500 G-0 

510 FOR I»1 TO 10 
520 G-G^l 

530 IF G-3 THEM 550 
540 NEXT I 
550 PRINT MEMORY 
560 RETURN 

PUN 

30505 

30473 

30505 



Branching out of a FOR/ NEXT loop in a subroutine will 
not limit memory, provided the subroutine is exited 



Notice that the six bytes allocated to store the return 
address are also freed. 
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4050 Series Applications Library Program Abstracts 



Order 

Documentation and program listings of each program are 
available] or a nominal charge. Programs will be put on tape for a 
small recording jee per program plus the charge for the tape 
cartridge. One tape will hold several programs. (The program 
material contained herein is supplied without warranty or 
representation oj any kind. Tektronix, Inc. assumes no repon- 
sibility and shall have no liability, consequential or otherwise, of 
any kind arising Jrom the use of this program material or any part 
thereoj.) 

Domestic U,S. Prices: 

Documentation and listings $20 per program 

Recording Fee 5 per program 

Tape Cartridge 30 per tape 



Contribute 

Contribute one program to the Library and receive three in 
exchange. Send in the membership card from your 4050 Series 
Graphic System Rejerence Manual to get the details. Or call us 
(503) 682^341 1, ext. 2618. 

Forms 

Please use the Applications Library Order Form. Order forms 
are included in the Membership Packet and are available from 
your local Tektronix Sales Engineer. 

Outside U.S. 

Program contributions or orders outside the U.S. must be 
processed through the local Tektronix sales office or sent to one 
oJ the Libraries serving your area. See Library Addresses section. 



ABSTRACT NUMBER: 51/00-1604/0 

Title: Analysis Of A Proving Ring Calibration 

Author: Colin MacKenzie 

National Research Council 
Ottawa. Ontario, CAxXADA 
Memory Requirement: 32K 
Peripherals: 463 1 Hard Copy Unit 
4662 Plotter 

4051R05 Binary ROM Pack 
Statements: 654 
Files: 2 Binary Program 
I Binary Data 

The program takes data obtained during calibration of a 
proving ring (applied load, initial zero reading, reading at 
load, final zero reading and temperature, taken in 
increments of approximately ten percent of capacity load 
in three independent runs of ten loadings) and derives an 
analytical expression for the calibration as a second 
degree polynominal in load, relating load to deflection for 
the standard temperature of 23°C. From this expression, 
calibration tables, relating deflection in divisions to load 
in pounds-force and newtons, are computed. 

Also produced by this program are: 

1. A graph of the difference of experimental readings 
and calibration equation versus percent of capacity 
load. 

2. A calibration information page which could be 
included along with the calibration tables and graph 
in a report of the calibration. 

3. The following tables: 

a. Input data 

b. Corrected and average deflections 



c. Experimental calibration factor 

d. Experimental deviations 

e. Fitted deilection compared with average obser\ed 
deflection 

f. Observed deflection minus fitted deflection 

g. Deviations from average and standard deviations 

h. Mean temperature, sum of squares of deviations, 
standard deviations and uncertainties 




s ^ i 5^- 0+*, ecrvrcui?. 



as » zi 

S' )■ 




•4"i or Colo' otrLfCT'io.' 



■ « 30 *et %z se ’a «a sa 

» OF OPACITY lOAO 

i-opehclse: proving ring, s/n 

RING I.N C0f<PPESSI0N capacity 2000 lBS 

calibrated i0 August igia 



ABSTRACT NUMBER: 51/00-1605/0 

Title: Shear and Moment Diagrams for Determinate 
Beams 

Author: David Q. Fletcher 

University of the Pacific 
Stockton, CA 

Memory Requirement: 24K 

Peripherals: Optional— 463 1 Hard Copy Unit 

Statements: 237 

Files: 1 ASCII Program 

The program accepts beam loading information in the 
form of magnitudes and locations of concentrated loads, 
distributed loads (uniform or linearly varying) and 
concentrated moments. It computes reactions and then 
displays a beam loading diagram and plots moment and 
shear diagrams. Any statically determinate beam can be 
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analyzed. In addition the magnitude and location of the 
absolute maximum values of shear and moment are 
given. 




ABSTRACT NUMBER: 51/00-4002/0 

Title: Blood Pressure Evaluation and 

Patient Data with Statistical Analysis 

Memory Requirement: 32K 
Peripherals: Optional — 4051R05 Binary Loader 
Optional — 463 1 Hard Copy Unit 
Files: I Program (ASCII or Binary) 

I Patient Data Tape (dedicated) 

I Stat 4 Data Tape 



Although this program was custom designed for a 
particular hospital, it serves as a pattern for other medical 
users. The graphically-aided data entry for blood pressure 
readings and TcP02 readings is unique. It's user-oriented 
with all data entry initiated through User-Definable Keys. 

The user keys in patient data: 



Name 

Record Number 
Age 

PVES # 



Sex 

Diabetic 

Smoker 

Standard Blood 
Pressure 



Next a diagram of the lower torso guides blood pressure 
and TcP02 readings. These readings and the ratio of 
normal blood pressure to actual are displayed on the 
screen. 



Then the patient’s history is keyed in: 



Influencing Drugs 
Pertinent Laboratory Data 
Operative Procedures 
Outcome of Operative Procedures 
Doppler Flow 
Pre or Post 



The program combines all of the data into one string and 
writes it to a patient data tape. Data for up to 240 patients 
may reside on one tape. A routine will select two data 
items from each patient file and write these items to 
another data tape in a format for use with Statistics 
Volume 4. In this case, the Linear Regression program 
analyzed sets of data. 



The first file on the patient data tape contains the number 
of full data files on the tape, and an index into the files by 
patient record number. 



Although no routines for data correction or special 
searching are provided, with the index already in place, it 
would be relatively simple to insert. 




ABSTRACT NUMBER: 51/00-5405/0 

Title: Polarized Light 

Author: Pilwon Kang 
Hood College 
Frederick, MD 
Memory Requirement: 8K 
Peripherals: Optional — 4631 Hard Copy Unit 
Statements: 384 
Files: 3 ASCII Program 

The program performs some of the fundamental 
calculations frequently encountered in the analysis of 
polarized light. The program is written in three parts, to 
fit into 8K of memory. 

File I — Plots the vibration pattern of light, when you 
specify the nature of polarization. 

File 2 — Calculates the parameters of the resultant light if 
polarized light is passed through a specified 
optical element. 

File 3— Obtains the following: 

1. The values of the reflection coefficient and 
reflectance. 

2. The Jones matrix of the reflected light. 

3. A plot of the reflectance as a function of the 
angle of incidence. 
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Pr«is RETURN hsr S«)«itioii Uld€. 

File 3 

ABSTRACT NUMBER: 51/00-8026/0 

Title: Tape Directory 

Author: Nick Ogbourne 

Comalco Aluminium Ltd. 

Tasmania, Australia 
Memory Requirement: 8K 
Peripherals: None 
Statements: 92 
Files: I ASCII Program 
I ASCII Text 

The program, located as the first ASCII program file on a 
tape, operates using the AUTOLOAD, provides a tape 
‘directory', multipage if necessary, and controls access to, 
and execution of any required program files. 

An ‘inde.N is maintained in file 2 (ASCII) which provides 
file number, program name and program description to 
the ‘directory’ program. 

It is not necessary to specify to the directory the type of 
the program (ASCII or Binary). Programs not required 
to be accessed by the directory, data files and text files 
may be recorded in file 2, providing a rapid means of 
‘TLIST’ing a tape. 




ABSTRACT NUMBER: 51/00-9532/0 

Title: Azimuthal Equidistant Projection 

Author: W. Tobler 

University of California 
Memory Requirement: 16K 
Peripherals: 4631 Hard Copy Unit or 
4661 Plotter 
Statements: 318 
Files: I ASCII Program 
1 Binary Data 

The program draws maps of the world centered at any 
origin^ Great circle distances and azimuths to all places 
are correct from the map center. The image of the 
geographic graticule and/or the world coastal outlines 
(included on tape) can be plotted. 

If the map is drawn on the plotter the program can also 
label places on the map, and prepares a small legend 
identifying the center of the map. The North and South 
poles are identified with N and S. 




ABSTRACT NUMBER; 51/00-9533/0 

Title: Pie Chart Routine 

Author: Herman D’Hondt 
Tektronix Australia 
Memory Requirement: 8K 
Peripherals: Optional— 4631 Hard Copy Unit 
Optional — 4662 Plotter 
Statements: 171 
Files: 1 ASCII Program 

The program will draw a pie chart diagram of data 
entered from the keyboard or from tape. The output 
shows a title, a subtitle and the pie chart with label and 
data values for each pie. Output may be to the 463 1 Hard 
Copy Unit or to the 4662 Plotter. 



Data values may be added or edited, using the User- 
Definable Keys. 
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l^ronbc 

CXJMA^nTED TO EXCELLENCE 






TEKTRONIX, INC. 
Information Display Group 
Applications Library 
Group 451 
P.O. Box 500 
Beaverton, Oregon 97005 






BTELLA 
60-307 
IF YOU 
PLEASE 


MCMORRAN 

HAOE HOOED 
CALL 2618 




ADDRESS CORRECTION REQUESTED 








Pictured here are Pat Kelley, Managing Editor, and Terry Davis, 
Editor, with the Awards of Distinction they received on behalf of 
TEKniques. The awards resulted from a communications contest 
sponsored by the Willamette Valley Chapter of the Society for Technical 
Communication. 
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